package com.zhugang.week04;

/**
 * @program algorithms
 * @description: insertSort
 * @author: chanzhugang
 * @create: 2022/06/15 22:43
 */
public class InsertSort {


    /**
     * 插入排序
     *
     * @param a
     * @param n
     */
    public void insertSort(int[] a, int n) {
        // 从未排序区间取值往已排序区间找到正确位置插入
        if (n <= 1) {
            return;
        }
        for (int i = 1; i < n; i++) {
            int val = a[i];
            int j = i - 1;
            for (; j >= 0; j--) {
                if (a[j] > val) {
                    // 值后移一位， j往前一位
                    a[j + 1] = a[j];
                } else {
                    break;
                }
            }
            // 插入正确位置
            a[j + 1] = val;
        }
    }
}